package org.leafstar.shortlink.project.service;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.IService;
import jakarta.servlet.ServletRequest;
import jakarta.servlet.ServletResponse;
import org.leafstar.shortlink.project.dao.entity.LinkDO;
import org.leafstar.shortlink.project.dto.req.LinkCreateReqDTO;
import org.leafstar.shortlink.project.dto.req.LinkPageReqDTO;
import org.leafstar.shortlink.project.dto.req.LinkUpdateReqDTO;
import org.leafstar.shortlink.project.dto.req.ShortLinkBatchCreateReqDTO;
import org.leafstar.shortlink.project.dto.resp.LinkCreateRespDTO;
import org.leafstar.shortlink.project.dto.resp.LinkGroupCountQueryRespDTO;
import org.leafstar.shortlink.project.dto.resp.LinkPageRespDTO;
import org.leafstar.shortlink.project.dto.resp.ShortLinkBatchCreateRespDTO;

import java.util.List;

/**
 * 短链接接口层
 */
public interface LinkService extends IService<LinkDO> {
    /**
     * 创建短链接
     * @param requestParam LinkCreateReqDTO
     * @return 创建的结果，比如gid,originLink,fullShortLink等
     */
    LinkCreateRespDTO createShortLink(LinkCreateReqDTO requestParam);

    /**
     * 分页查询短链接
     * @param requestParam 带有分页的参数，需要gid,size,current
     * @return page集合
     */
    IPage<LinkPageRespDTO> pageLink(LinkPageReqDTO requestParam);
    /**
     * 查询短链接分组内的链接数量
     * @param requestParam gids
     * @return LinkGroupCountQueryRespDTO列表
     */
    List<LinkGroupCountQueryRespDTO> listGroupShortLinkCount(List<String> requestParam);
    /**
     * 更新短链接
     * @param requestParam 请求更新实体
     * @return 更新结果
     */
    void updateShortLink(LinkUpdateReqDTO requestParam);
    /**
     * 短链接重定向，即核心跳转功能
     * @param shortUri suffix
     * @param request 请求
     * @param response 返回
     */
    void restoreUrl(String shortUri, ServletRequest request, ServletResponse response);

    /**
     * 批量创建短链接
     *
     * @param requestParam 批量创建短链接请求参数
     * @return 批量创建短链接返回参数
     */
    ShortLinkBatchCreateRespDTO batchCreateShortLink(ShortLinkBatchCreateReqDTO requestParam);
}
